Top 10k strings from Make-a-Chip (1984)(Sinclair Research)[a].tzx in <root> / bin / z80 / software / Sinclair Spectrum Collection TOSEC.exe / Sinclair ZX Spectrum - Utilities & Educational / Sinclair ZX Spectrum - Utilities & Educational - [TZX] (TOSEC-v2007-01-01) /

Back to the directory listing

   6 MAKE A CHIP
   5 n7,n8;" ";
   5 n7,n7;"0";
   5 n5,n3;" ";
   5 n4,n8;" ";
   5 n4,n7;"1";
   5 n2,n2;" ";
   5 e$(n2)="1":
   5 e$(n2)="0"
   5 e$(n1)="1":
   5 e$(n1)="0"
   4 y1+n1,x1;"  ":
   4 n7,n8;"0":
   4 n5,n3;"0";
   4 n4,n8;"0":
   4 e$(n4)="1":
   4 e$(n4)="0"
   4 e$(n3)="1":
   4 e$(n3)="0"
   3 n7,n7;"1";
   3 n4,n7;"0";
   3 n3*n7,n;" ";
   3 n2,n2;"1":
   3 n2,n2;"0":
   3 "'"          
   2 v=g(t,n2)-n8-n8:
   2 to continue, or 
   2 t=f(f,n1):
   2 st=fob+s1-n1:
   2 s=o(o,n1):
   2 q=g(s,n1):
   2 p=g(s,n2):
   2 n9,n8;"1";
   2 n9,n8;"0";
   2 n9,n5*n5;"0 0";
   2 n9,n0+n5;"1";
   2 n7,n8;"1":
   2 n7,n7;" ";
   2 n7,n0+n5;"1";
   2 n6*n2,n8;"1";
   2 n6*n2,n8;"0";
   2 n5;"in      <-----gates---->     out
   2 n5,n3;"1";
   2 n4,n8;"1":
   2 n4,n7;" ";
   2 n3,n0+n5;"1";
   2 n0+n1,n;"1";
   2 n0+n1,n;"0";
   2 n$(n1)="s"
   2 n$(n1)="Y"
   2 n$(n1)="S"
   2 m(cx-n1,cy,n1)=g:
   2 m(cx-n1,cy,n1)
   2 l(in)=l(in)+n1:
   2 YT,XT;"  ";
   2 YT+N1,XT;"  "
   2 Y1,X1;"  ";
   2 Y1+N1,X1;"  ";
   2 ;"OFF   |   OFF"'
   2 " ",-n8-n8:
   2             
   1 y1,x1;"  ";
   1 y1+n1,x1;"  "
   1 y+n1,x;g$(n3
   1 y+N1,x;"  "
   1 v=g(t,n1):
   1 v=g(t,n1)+pt:
   1 v=g(S,n2):
   1 v=g(S,n1):
   1 truth  table
   1 t>n3*n4)+(n4
   1 t=o+n4*n4:
   1 t=n0+n6+o:
   1 t1<n0+n7)+(
   1 t(i1)-p,n:
   1 st=fib+n8*(-n1+
   1 st=ffb+n8:
   1 st=ffb+n8+n8:
   1 st=fbb+n8:
   1 st=fbb+n8+n8:
   1 select output lines
   1 s>n0+n2)+(n4
   1 s=m(j,k,n3):
   1 s=m(j,k,n2):
   1 s=f(f,n3):
   1 s=f(f,n2):
   1 s$(n9,n4):
   1 s$(n7)="OUT":
   1 s$(n6)="STOP":
   1 s$(n5)="NOR":
   1 s$(n4)="NAND":
   1 s$(n3)="NOT":
   1 s$(n2)="OR":
   1 s$(n1)="AND":
   1 q=g(T,n1)+PT:
   1 pt=+n4-(n2
   1 p=g(T,n2)-16
   1 p3=fnc+n3:
   1 p3,m(j,k,n1)
   1 p+n8,q-n7,n2
   1 p+n6,q-n7:
   1 p(o)=o(o,n2));("Your guess was wrong"
   1 out=m(x2-N1,y2,n5):
   1 out=m(x,y,n5):
   1 o(o,n2)=out
   1 o(o,n2));".  ":
   1 o(o,n1)=in:
   1 n9,n;"When we draw logic gates across the screen we work out their    function from left to right."''"The computer works out each     column of gates in one very     small interval of time."
   1 n9,n;"When input S is set, the output Q is set on, and is fed back as signal P for the next cycle.    Further cycles will leave Q on  until the input R is set, at    which time Q is reset to zero   (and fed back as P).  This will continue until S is set again. Sand R can't both be set together- but assume in the truth table that such situations set Q to   zero."
   1 n9,n;"Watch what happens to the outputof each gate for each set of    input values. Note how the same values occur at both outputs."
   1 n9,n;" ________":
   1 n9,n;" S R P  Q";
   1 n9,n3*n5;"1";
   1 n9,n3*n5;"0";
   1 n9,n3*n0;"0":
   1 n9+n9,n;"Please wait while I check your  circuit is valid.":
   1 n9+n9,n;"Now I shall calculate the outputvalues."
   1 n8,n5*n5;"in  out";
   1 n8,n5*n5;"_______";
   1 n8,n1;in2:
   1 n8,n1;" ";
   1 n7,n7+n7;" ":
   1 n7,n1;" ";
   1 n7,n0+n5;"0";
   1 n7+n7,n;"Watch what happens with various sets of inputs."
   1 n7*n3,n;"select the next input.    ":
   1 n6;"MAKE A CHIP":
   1 n6,n5*n5;"1 1":
   1 n6,n1;in1:
   1 n6,n1;" ";
   1 n6,n0+n4;"| |";
   1 n6*n2,n5*n5;"1 1":
   1 n6*n2,n3*n0;"1":
   1 n5,n5*n5;"in  out":
   1 n5,n5*n5;"1 0";
   1 n4;"  "'"  ":
   1 n4,n;"switch1";
   1 n4,n;"switch";
   1 n4,n;"S"''"R";
   1 n4,n5*n5;"0 1";
   1 n4,n4+n0;"| |";
   1 n3,n;"ignition";
   1 n3,n5*n5;"table";
   1 n3,n5*n5;"0 0";
   1 n3,n0+n5;"0";
   1 n3,n0+n1;"
   1 n2,n5*n5;"in  out";
   1 n2,n5*n5;"_______";
   1 n2,n5*n5;"Truth";
   1 n1;p+n8,q-n7,n2
   1 n1;p+n6,q-n7:
   1 n1;"_____________________________";
   1 n1;"Answer  8"
   1 n1/n2,-n0:
   1 n0,n;"switch2"
   1 n0,n;"reversing";
   1 n0,n;"Now we will see that a NOR gate is really the same as an OR gateand a NOT gate in series."
   1 n0,n;"Next, look what happens to the  NAND gate when both inputs are  the   same.":
   1 n0,n;" 0 0 0"'" 0 1 0"'" 1 0 0"'" 1 1 0  0"'" 0 0 1"'" 0 1 1"'" 1 0 1"'" 1 1 1  0"
   1 n0,n5*n5;"0 1";
   1 n0,n3*n0;"1":
   1 n0,n2;"Turn your tape recorder off."
   1 n0+n9,n;"Output ";o;" will have value ?":
   1 n0+n9,n;"Output ";o;" was ";o(o,n2)'("You guessed correctly"
   1 n0+n9,n5*n5;ip:
   1 n0+n7,n;"Would you like to give the      inputs new values?  Type I to   set the inputs, or S to stop."
   1 n0+n7,n;"Would you like to give the      inputs new values?  Type I to   set the inputs or C to continue."
   1 n0+n7,n;"Type A to amend the circuit,         R to set inputs & run,          L to learn about gates,         E to see example circuits,      S to stop."
   1 n0+n7,n;"There is no gate here although  you are using an output from    this position.  Please edit thiscircuit to make it correct.":
   1 n0+n7,n;"There is a feedback line betweenthese gates.  This could make   the ciruit be undetermined for  certain input values.           ":
   1 n0+n7,n;"Do you want me to print a copy  of the circuit on ZX Printer?   Type C for a copy, or type N forthe next set of input values.";
   1 n0+n7,n;"Do you recognise the output     pattern?  This circuit is how anOR gate is made up of NAND gates":
   1 n0+n7,N;"Type F to try another set of    initial feedback values, type I to try another set of inputs or type S to STOP."
   1 n0+n7,N;"I shall select a set of inputs":
   1 n0+n1,n;"light switch"
   1 n0+n1,n5*n5;"1 0";
   1 n0+n1,n3*n0;"1":
   1 n$(n1)="y")
   1 n$(n1)="y" 
   1 more i/p etc then mode 1
   1 means the light is waiting to be set.":
   1 m(x,y,n1)>n
   1 m(x,y,n1)=n
   1 m(n3,n4,n5):
   1 m(k,j,n3)=n
   1 m(k,j,n3)=in:
   1 m(k,j,n2)=n
   1 m(k,j,n2)=in:
   1 m(k,j,n1)=n3):
   1 m(k,j,n1)=n
   1 m(j,k,n1)=n3
   1 m(i,j,n4)=m(i,j,n5):
   1 m(gx,gy,n3)=in2:
   1 m(gx,gy,n2)=in1:
   1 m(cx-n1,cy,n4)=iP:
   1 m(J,cy,n5)=out
   1 m(J,cy,n1)=n
   1 logic elements
   1 l(in2)=l(in2)+n1
   1 l(in1)=l(in1)+1
   1 k,n;i(i);" "'"  "
   1 k,n;i(i);" "
   1 j(n3,n1)=n1:
   1 j(n2,n1)=n1:
   1 j(n1,n1)=J
   1 j(j,n3)=n4:
   1 j(j,n3)=n3:
   1 j(j,n3)=n2:
   1 j(j,n3)=n1:
   1 j(j,n2)=n7:
   1 j(j,n2)=n2:
   1 j(j,n2)=n0:
   1 j(j,n2)=15
   1 ip1=wt+n0:
   1 in=on)+(lf
   1 in=off)+(lf
   1 in2=on)+(lf
   1 in2=m(x2-n1,y2,n5):
   1 in2=m(x2-n1,y2,n4):
   1 in2=i(y2):
   1 in1=on)+(lf
   1 in1=m(x2-n1,y2,n5):
   1 in1=m(x2-n1,y2,n4):
   1 in1=i(y2):
   1 g=m(j,k,n1):
   1 for OFF   
   1 fnz=fny+n3:
   1 fny=fnx+n3:
   1 fnx=bt+n3:
   1 fnc=fnz+n3:
   1 ffb=n5*n5:
   1 f(n1,n1)=n
   1 f(n0+n2,n3)
   1 f(f,n2)=s:
   1 f(f,n1)=t:
   1 cy=n4)+(cy+n1
   1 cy=n3)+(n3*n5
   1 cy=n2)+(n0
   1 cy=n1)+(n7
   1 cy=n1)+(cy-n1
   1 cx=xl)+(cx-n1
   1 cx=xh)+(cx+n1
   1 cx=n4)+(n3*n0
   1 cx=n3)+(22
   1 cx=n2)+(n5*n3
   1 cx=n1)+(n8
   1 c(nx)=c(nx)+(n1
   1 c(n4)=n5*n5:
   1 c(n3)=n0+n7:
   1 b,A;"SAVING - do not turn tape off  ":
   1 a$(n1)="C"
   1 ___________
   1 Where do you want to start?     
   1 ST=ST+H-N1:
   1 S$(N9)="NEW"
   1 S$(N8)="COPY":
   1 Please wait while I load";
   1 Please press any key to continue
   1 PART 5    
   1 PART 4    
   1 PART 3    
   1 PART 2    
   1 N9,N;"In the first part we learnt thata NAND gate is really an AND    gate followed by a NOT gate. Theabove circuit shows two outputs,one from a NAND gate, the other from a sequence of gates."
   1 N3,N;"In the first part of the programyou learnt about gates - what   they are called and under what  conditions they are ON or OFF."''"In this part of the program we  shall see how to join gates to  make circuits, and what FEEDBACKis."''"The third part of the program iswhere you design your own       circuits."
   1 N1;"?";IP:
   1 M(CX-N1,CY,N1)
   1 LST=-n1+n2^LT:
   1 J(n4,N1)=n1:
   1 J(J,N2),N;J(J,N1)
   1 J(J,N1)=N:
   1 I=M(J,K,n3):
   1 I=M(J,K,n2):
   1 I(J(J,N3))=J(J,N1):
   1 F(N0+N2,N3):
   1 Do you want to set any more     outputs?  Answer 
   1 Do you want to edit the circuit?
   1 Do you want sound? Answer 
   1 Computer hardware is essentiallyquite simple,and can be thought of as five connecting elements."
   1 CHIP      
   1 B(H+N8+N8)=N)
   1 B$(S,N3)-N8:
   1 B$(S,N3)-N8-N8:
   1 B$(S,N2)-N8:
   1 B$(S,N2)+N8:
   1 B$(S,N1)+N8:
   1 B$(S,N1)+N8+n8:
   1 B$(N4*N4,N3):
   1 B$(I)="000":
   1 AND OR  NOT NANDNOR STOPOUT COPYNEW 
   1 ;"two values and the";
   1 ;"the truth table."
   1 ;"reversing";
   1 ;"previous cycle."
   1 ;"is a SET/RESET";
   1 ;"in      <-----gates---->     out":
   1 ;"carry, which is a";
   1 ;"bistable."
   1 ;"We could use an OR gate for a   light which has two switches.   The light would be on if EITHER switch 1 OR switch 2 is on."
   1 ;"Type 1 for the computer to try  each set of inputs in turn, or  type 2 (or 3) to try particular sets of inputs.  Type 
   1 ;"This circuit  ";
   1 ;"ON    |   ON"
   1 ;"ON    |   OFF"'
   1 ;"Now let's complete";
   1 ;"In each cycle of our";
   1 ;"I am drawing the connexion"
   1 ;"'add machine', we add";
   1 3 to guessthe output for your input values"
   1 000000000000000000000000000000000000000000000000L
   1 .A signal high represents 1, and low represents 0.
   1 ."''"Feedback is a means of modifyingthe input to one gate as a      result of a previous output fromanother gate,each gate being setduring a time cycle."
   1 . When the NOT is after the OR gate we call it a 
   1 .  This is an OR   gate followed by a NOT gate."''"Try and complete the truth tableby setting the inputs to the    gate.
   1 ,n;"ignition 
   1 ,n;"carry  1":
   1 ,n;"Where do you want the lines intothe outputs to come from?       First select an output, by usingcursor controls and then press  enter.":
   1 ,n;"What do you think the outputs   will be?"
   1 ,n;"We will put a light at each of  the inputs and outputs to see   what happens when different     logic values are input."
   1 ,n;"We shall now look at a gate withonly one input.  The output is  always the opposite of the      input.  We call this a 
   1 ,n;"This is how a NAND gate is drawnNow try and complete the truth  table.":
   1 ,n;"This gate has no output, this   however is not an error but is aspare circuit.  You may editthiscircuit to correct this fault."
   1 ,n;"The symbol on the screen is     called an AND gate, and is how  we represent a logic AND in     circuit drawings. The circuit   will put the light (or output)  ON if both inputs are set to ON."
   1 ,n;"The last gate we shall look at  is called 
   1 ,n;"So we need to set an initial    value for the output of the     source gate."
   1 ,n;"Set the inputs to the AND gate  to see what values turn the     reversing light ON."''"The computer will fill in a row in the truth table for each set of inputs you try.":
   1 ,n;"Please wait while I remember anddraw your circuit."
   1 ,n;"Now set the inputs and see what happens to the output and to thetruth table."
   1 ,n;"Do you recognise the pattern of the truth table?";:
   1 ,n;"Another type of gate is called  an 
   1 ,n0;"add bigger numbers...":
   1 ,n0;"That was fairly easy.";
   1 ,n0;"Now we shall try to";
   1 ,n0;" with no carry.";
   1 ,n0;" 5 plus 8 is 3 carry 1";
   1 ,n0;" 1 plus 1 (carry) is 2";
   1 ,N;"Type R to run the circuit,           C to continue design,           L to learn about gates,         E to see the examples.";
   1 ,N;"Type QUIT to leave this part of the program."
   1 , as shown next.":
   1 , and eight bits are referred to  as a byte.
   1 ))/n2^n0)/n0;"K"
   1 ''"You have now learnt about the   basic elements used in circuit  design.  The next part of the   program enables you to combine  gates and to see what happens   with a selection of different   input values."
   1 ''"When the NOT gate is immediatelyafter the AND gate we call it a 
   1 ''"These elements can be made from just one type of electronic     circuit.The complex part of the computer being  how  these      circuits are joined together."
   1 ''"The next page shows a picture ofthe way a computer is made up ofthe five elements."
   1 ''"The electric signals in the     computer are either 
   1 ''"Process is a way of saying      'work'.  The computer will work with the information held in itsmemory or the information that  you have 'input'.  There must bean 'output' so the computer can tell you what it has worked out.The control looks after  what   the computer is doing."
   1 ''"Now select the values for the   inputs to the circuit."
   1 ''"NAND and NOR gates are very easyto construct and all other gatescan be made by combining NAND   gates."
   1 ''"Do you want to continue with    your old circuit or to start a  new design?"''"Type O for your old circuit or  N for a new circuit."
   1 ''"Another example of a circuit    with feedback is a BISTABLE.    These can be used for registers and store in computers. They canhold, for another cycle, the    previous output of a gate.":
   1 ''"A binary digit is called 
   1 '"You can not position a gate     here!  Try again.":
   1 '"We will record the input and    output combinations in a 
   1 '"To move the cursor use keys 5-8.When you press enter you will beable to specify the type of gateor enter a command."
   1 '"To explain this, think of addingtwo numbers.":
   1 '"There are three basic logic"'"elements.  They are called 
   1 '"The first part of this program  tells you about circuit design. The second part shows you some  example circuits. The third partlets you experiment and design  circuits."''"If you have not run the program before, you should start with   the first part."
   1 '"If you 'BREAK' into the program,you should not type RUN as this will lose the data.  Type GOTO 1instead."
   1 '"Consider a car with a reversing light.  For the reversing light to be on, the reversing light   switch must be on whilst the    ignition is on.In logic circuitswe can say the light will be ON when the ignition is ON 
   1 '"A truth table usually has 1 and 0 instead of ON and OFF."
   1 "You have missed out an input to this gate, where should it come from?":
   1 "You already have a gate here!   You can only change the gate to one with the SAME number of     inputs.":
   1 "Where should the output come    from?  Use cursor controls to   select the position, then press enter."
   1 "What type of gate do you want tofind out about?"''"     AND  
   1 "We are now going to find out    about 
   1 "Type your command: ";a$:
   1 "Type the gate name ";g$:
   1 "Type STOP to stop design             COPY tO print circuit           OUT to set outputs              NEW to start again,        or AND OR NOT NAND NOR for gate."
   1 "This output is already being    used. Remember there can only beone line into an output.":
   1 "Sometimes we wish to use a NOT  gate just after an AND or an OR gate.  To do this we just draw  the small circle from the NOT   gate where we wish the NOT gate to go."
   1 "Select where the inputs to this gate come from.  Position the   cursor where the input is from, or at one of the outputs if you are unsure."
   1 "R, C, L or E :";a$:
   1 "Part 1 (learn), 2 (examples),   3 (experiment) or 4(STOP)";n$:
   1 "O or N :";a$:
   1 "Information is represented in a computer as a list of 1's and   0's. This type of representationis called binary. Binary is     used a lot in computing because electronic circuits can only be ON or OFF."
   1 "In this section we have seen howto make a circuit from gates. Inreality you would do this with  transistors, chips, bits of wireand solder."''"We have also seen how all the   gates can be constructed by     combining just one type of gate."''"Lastly we have looked at how we can make storage by using feed- back."
   1 "In this part you can experiment with the gates and try to createyour own circuits."''"You may use any of the gates -  AND, OR, NOT, NOR and NAND.  Youhave a command COPY which will  copy your circuit to the        ZX Printer if it is connected.  A command OUT allows you to set up to 4 outputs.  STOP will stopthe design part, I will then    check the circuit is valid, and will work out the output for anyinput combination you select."''"Have fun!":
   1 "In part 1, we said all gates canbe made from a combination of   NAND gates. We shall now see howwe can make an OR gate."
   1 "I or S: ";a$:
   1 "I or C: ";a$:
   1 "F, I or S :";a$
   1 "Electronic circuits contain"'"transistors. Common arrangementsof transistors are represented"'"symbolically by 
   1 "C (Copy) or N (Next inputs) ";a$:
   1 "A, S, R, L or E :";a$:
   1 "1, 2 or 3 :";a$:
   1 "''"     OR   
   1 "''"     NOT  
   1 "  The output is"'"equivalent to the output from a NOT gate.  So we can make NOT   gates from NAND gates - and alsowe can make AND gates (NAND thena NOT gate).":
   1  the reversing light switch is ON.
   1  switch  |  light";
   1  means the light is on"''"
   1  means the light is off"''"
   1  in circuit diagrams.
   1  from the";
   1  for ON, and 
   1  CONTROL  
   1   PROCESS   
   1   MEMORY  
   1       NOR   
   1       NAND